<template>
    <div>
      <video-player class="video-player vjs-custom-skin"
          ref="videoPlayer"
          :playsinline="true"
          :options="playerOptions"
        ></video-player>
    </div>
</template>

<script>
import Vue from 'vue'
import VideoPlayer from 'vue-video-player'
import 'vue-video-player/node_modules/video.js/dist/video-js.css'
import 'vue-video-player/src/custom-theme.css'
Vue.use(VideoPlayer)

export default {
  props: {
    videoUrl: String,
    posterUrl: String
  },
  data () {
    return {
      playerOptions: {
        playbackRates: [], // 播放速度
        autoplay: false, // 如果true,浏览器准备好时开始回放。
        muted: false, // 刚开始是否消除任何音频。
        loop: false, // 循环播放
        preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频（如果浏览器支持）
        language: 'zh-CN',
        aspectRatio: '16:9', // 将播放器置于流畅模式，并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字（例如"16:9"或"4:3"）
        fluid: true, // 当true时，Video.js player将拥有流体大小。换句话说，它将按比例缩放以适应其容器。
        sources: [{
          type: '', // 这里的种类支持很多种：基本视频格式、直播、流媒体等，具体可以参看git网址项目
          src: '' // url地址
        }],
        poster: '', // 你的封面地址
        // width: document.documentElement.clientWidth, //播放器宽度
        notSupportedMessage: '此视频暂无法播放，请稍后再试', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
        controlBar: {
          timeDivider: true, // 时间记录
          durationDisplay: true, // 总时间
          remainingTimeDisplay: false, // 播放倒计时
          fullscreenToggle: true, // 全屏按钮
          seekToLive: false, // live图标
          pictureInPictureToggle: false // 画中画
        }
      }
    }
  },
  mounted () {
    // 视频封面地址赋值 重置
    this.playerOptions.poster = this.posterUrl
    // 视频地址赋值 重置
    this.playerOptions.sources[0].src = this.videoUrl
  }
}
</script>
